package curiosity.dao;

import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;

import curiosity.modelo.RegistrarPuesto;
import curiosity.excepcion.DAOExcepcion;
import curiosity.util.ConexionBD;


	public class RegistrarPuestoDAO extends BaseDAO{

	public RegistrarPuesto insertar(RegistrarPuesto ins) throws DAOExcepcion{
	
	
		String query = "INSERT INTO registrarpuesto(afuncional, nombre_puesto, descripcion) VALUES (?, ?, ?)";
		Connection con = null;
		PreparedStatement stmt = null;
		ResultSet rs = null;
	
		try {
			con = ConexionBD.obtenerConexion();
			stmt = con.prepareStatement(query);

			
			stmt.setString(1, ins.getafuncional());
			stmt.setString(2, ins.getnombre_puesto());
			stmt.setString(3, ins.getdescripcion());
			
			int i = stmt.executeUpdate();
			if (i != 1){
				throw new SQLException("No se pudo insertar");
			}
			
			int id = 0;
			query = "SELECT LAST_INSERT_ID()";
			stmt = con.prepareStatement(query);
			rs = stmt.executeQuery();
			if (rs.next()) {
				id = rs.getInt(1);
				
			}
			ins.setidpuesto_laboral(id);
			} catch (SQLException e){
				System.err.println(e.getMessage());
				throw new DAOExcepcion(e.getMessage());
					
			} finally {
				this.cerrarResultSet(rs);
				this.cerrarStatement(stmt);
				this.cerrarConexion(con);
			}	
			
			return ins;
			
	}}